<!--全部商品页面组件(包括全部商品,商品分类,商品搜索)-->
<template>
  <div class="goods" id="goods" name="goods">
    <HeadLayout/>
    <!-- 面包屑 -->
    <div class="breadcrumb">
      <el-breadcrumb separator-class="el-icon-arrow-right">
        <el-breadcrumb-item to="/">首页</el-breadcrumb-item>
        <el-breadcrumb-item>逛好店</el-breadcrumb-item>
<!--        <el-breadcrumb-item v-if="search">搜索</el-breadcrumb-item>-->
<!--        <el-breadcrumb-item v-else>分类</el-breadcrumb-item>-->
<!--        <el-breadcrumb-item v-if="search">{{search}}</el-breadcrumb-item>-->
      </el-breadcrumb>
    </div>
        <!-- 面包屑END -->

    <!-- 分类标签 -->
<!--    <div class="nav">-->
<!--      <div class="product-nav">-->
<!--        <div class="title">分类</div>-->
<!--        <el-tabs v-model="activeName" type="card">-->
<!--          <el-tab-pane-->
<!--            v-for="item in categoryList"-->
<!--            :key="item.category_id"-->
<!--            :label="item.category_name"-->
<!--            :name="''+item.category_id"-->
<!--          />-->
<!--        </el-tabs>-->
<!--      </div>-->
<!--    </div>-->
    <!-- 分类标签END -->

    <!-- 主要内容区 -->
    <div class="main">
      <div class="list">
<!--        <MyList :list="storeList" ></MyList>-->
          <ul>
            <li v-for="item in storeList" :key="item.id">
              <router-link :to="{ path: '/shopGoods', query: {shopID:item.id} }">
                <!--          店铺头像（封面）-->
                <img :src="item.shopImg" alt />
                <!--          店铺名称-->
                <h2>{{item.shopName}}</h2>
                <!--          店铺简介-->
                <h3>{{item.shopName}}</h3>
                <p>
                  <span>自营</span>
                </p>
              </router-link>
            </li>
          </ul>
<!--        <div v-else class="none-product">抱歉没有找到相关的店铺，请看看其他的店铺</div>-->
      </div>
      <!-- 分页 -->
      <div class="pagination">
        <el-pagination
          background
          layout="prev, pager, next"
          :page-size="pageSize"
          :total="total"
          @current-change="currentChange"
        ></el-pagination>
      </div>
      <!-- 分页END -->
    </div>
    <!-- 主要内容区END -->
  </div>
</template>
<script>
import HeadLayout from "@/components/HeadLayout";
export default {
  components:{
    'HeadLayout':HeadLayout
  },
  data() {
    return {
      categoryList: "", //分类列表
      categoryID: [], // 分类id
      product: "", // 商品列表
      productList: "",
      total: 0, // 商品总量
      pageSize: 15, // 每页显示的商品数量
      currentPage: 1, //当前页码
      activeName: "-1", // 分类列表当前选中的id
      search: "" ,// 搜索条件
      storeList:[]
    };
  },
  mounted() {

    // 获取分类列表
    // this.getCategory();
    //获取所有店铺
    this.getStoreList();
  },
  // activated() {
  //   this.activeName = "-1"; // 初始化分类列表当前选中的id为-1
  //   this.total = 0; // 初始化商品总量为0
  //   this.currentPage = 1; //初始化当前页码为1
  //   // 如果路由没有传递参数，默认为显示全部商品
  //   if (Object.keys(this.$route.query).length == 0) {
  //     this.categoryID = [];
  //     this.activeName = "0";
  //     return;
  //   }
  //   // 如果路由传递了categoryID，则显示对应的分类商品
  //   if (this.$route.query.categoryID != undefined) {
  //     this.categoryID = this.$route.query.categoryID;
  //     if (this.categoryID.length == 1) {
  //       this.activeName = "" + this.categoryID[0];
  //     }
  //     return;
  //   }
  //   // 如果路由传递了search，则为搜索，显示对应的分类商品
  //   if (this.$route.query.search != undefined) {
  //     this.search = this.$route.query.search;
  //   }
  // },
  watch: {
    // 监听点击了哪个分类标签，通过修改分类id，响应相应的商品
    activeName: function(val) {
      if (val == 0) {
        this.categoryID = [];
      }
      if (val > 0) {
        this.categoryID = [Number(val)];
      }
    //   // 初始化商品总量和当前页码
      this.total = 0;
      this.currentPage = 1;
    //   // 更新地址栏链接，方便刷新页面可以回到原来的页面
      this.$router.push({
        path: "/goods",
        query: { categoryID: this.categoryID }
      });
    },
    // 监听搜索条件，响应相应的商品
    search: function(val) {
      if (val != "") {
        this.getProductBySearch(val);
      }
    },
    // 监听分类id，响应相应的商品
    categoryID: function() {
      this.getData();
      this.search = "";
    },
    // 监听路由变化，更新路由传递了搜索条件
    $route: function(val) {
      if (val.path == "/goods") {
        if (val.query.search != undefined) {
          this.activeName = "-1";
          this.currentPage = 1;
          this.total = 0;
          this.search = val.query.search;
        }
      }
    }
  },
  methods: {
    // 返回顶部
    backtop() {
      const timer = setInterval(function() {
        const top = document.documentElement.scrollTop || document.body.scrollTop;
        const speed = Math.floor(-top / 5);
        document.documentElement.scrollTop = document.body.scrollTop =
          top + speed;

        if (top === 0) {
          clearInterval(timer);
        }
      }, 20);
    },
    // 页码变化调用currentChange方法
    currentChange(currentPage) {
      this.currentPage = currentPage;
      if (this.search != "") {
        this.getProductBySearch();
      } else {
        this.getData();
      }
      this.backtop();
    },
    getStoreList(){
      this.$axios
          .get("http://localhost:2321/shop/getall")
          .then(res => {
            console.log(res);
            this.storeList=res.data;

          })
          .catch(err => {
            return Promise.reject(err);
          });
    }
    // 向后端请求分类列表数据
    // getCategory() {
    //   this.$axios
    //     .post("/api/product/getCategory", {})
    //     .then(res => {
    //       const val = {
    //         category_id: 0,
    //         category_name: "全部"
    //       };
    //       const cate = res.data.category;
    //       cate.unshift(val);
    //       this.categoryList = cate;
    //     })
    //     .catch(err => {
    //       return Promise.reject(err);
    //     });
    // },
    // 向后端请求全部商品或分类商品数据
    // getData() {
    //   // 如果分类列表为空则请求全部商品数据，否则请求分类商品数据
    //   const api =
    //     this.categoryID.length == 0
    //       ? "/api/product/getAllProduct"
    //       : "/api/product/getProductByCategory";
    //   this.$axios
    //     .post(api, {
    //       categoryID: this.categoryID,
    //       currentPage: this.currentPage,
    //       pageSize: this.pageSize
    //     })
    //     .then(res => {
    //       this.product = res.data.Product;
    //       this.total = res.data.total;
    //     })
    //     .catch(err => {
    //       return Promise.reject(err);
    //     });
    // },
    // 通过搜索条件向后端请求商品数据
    // getProductBySearch() {
    //   this.$axios
    //     .post("/api/product/getProductBySearch", {
    //       search: this.search,
    //       currentPage: this.currentPage,
    //       pageSize: this.pageSize
    //     })
    //     .then(res => {
    //       this.product = res.data.Product;
    //       this.total = res.data.total;
    //     })
    //     .catch(err => {
    //       return Promise.reject(err);
    //     });
    // }
  }
};
</script>

<style scoped>
.goods {
  background-color: #f5f5f5;
}
/* 面包屑CSS */
.el-tabs--card .el-tabs__header {
  border-bottom: none;
}
.goods .breadcrumb {
  height: 50px;
  background-color: white;
}
.goods .breadcrumb .el-breadcrumb {
  width: 1225px;
  line-height: 30px;
  font-size: 16px;
  margin: 0 auto;
}
/* 面包屑CSS END */

/* 分类标签CSS */
.goods .nav {
  background-color: white;
}
.goods .nav .product-nav {
  width: 1225px;
  height: 40px;
  line-height: 40px;
  margin: 0 auto;
}
.nav .product-nav .title {
  width: 50px;
  font-size: 16px;
  font-weight: 700;
  float: left;
}
/* 分类标签CSS END */

/* 主要内容区CSS */
.goods .main {
  margin: 0 auto;
  max-width: 1225px;
}
.goods .main .list {
  min-height: 650px;
  padding-top: 14.5px;
  margin-left: -13.7px;
  overflow: auto;
}
.goods .main .pagination {
  height: 50px;
  text-align: center;
}
.goods .main .none-product {
  color: #333;
  margin-left: 13.7px;
}

.goods .main .list ul li {
  z-index: 1;
  float: left;
  width: 234px;
  height: 280px;
  padding: 10px 0;
  margin: 0 0 14.5px 13.7px;
  background-color: white;
  -webkit-transition: all 0.2s linear;
  transition: all 0.2s linear;
  position: relative;
}
.goods .main .list ul li:hover {
  z-index: 2;
  -webkit-box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1);
  -webkit-transform: translate3d(0, -2px, 0);
  transform: translate3d(0, -2px, 0);
}
.goods .main .list ul li img {
  display: block;
  width: 160px;
  height: 160px;
  background: url(../assets/imgs/placeholder.png) no-repeat 50%;
  margin: 0 auto;
}
.goods .main .list ul li h2 {
  margin: 25px 10px 0;
  font-size: 14px;
  font-weight: 400;
  color: #333;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}
.goods .main .list ul li h3 {
  margin: 5px 10px;
  height: 18px;
  font-size: 12px;
  font-weight: 400;
  color: #b0b0b0;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}
.goods .main .list ul li p {
  margin: 10px 10px 10px;
  text-align: center;
  color: red;
}
.goods .main .list ul li p .del {
  margin-left: 0.5em;
  color: #b0b0b0;
  text-decoration: line-through;
}
.goods .main .list #more {
  text-align: center;
  line-height: 280px;
}
.goods .main .list #more a {
  font-size: 18px;
  color: #333;
}
.goods .main .list #more a:hover {
  color: #ff6700;
}
.goods .main .list ul li .delete {
  position: absolute;
  top: 10px;
  right: 10px;
  display: none;
}
.goods .main .list ul li:hover .delete {
  display: block
}
.goods .main .list ul li .delete:hover {
  color: #ff6700;
}
/* 主要内容区CSS END */



</style>
